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(57) Abstract 



An MPEG-2 or other compressed video stream (CP) can be manipulated as separate information bus (IB) and coefficient (CP*) j 
streams. The information bus stream (IB) contains motion vector information bui 3lso information derived from a previous decoding • 
operation (14, iS) for use in a subsequent coding operation (22). Processing in the coefficient domain enables bit rate conversion wjihoui 
decoding to the pixel level and also simplifies the combination of MPEG layers. 
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VIDEO COMPRESSION 

This invention relates to video compression. 

In an important example, the present invention concerns itself with 
MPEG-2 which is an emerging standard for the digital compression of video 
signals. As is well known, MPEG-2 is a development of MPEG-1 which. 

5 was directed towards low bit rate storage applications such as CD-ROM and 
had no interlace capability. Without specifying the manner in which a video 
signal is coded, MPEG-2 defines a bitstream syntax and a set of rules for a 
decoder to regenerate the picture. 

One object of the present invention, in certain of its forms, is to 

10 provide improved MPEG-2, or other compression, encoders and decoders. 

In certain of its aspects, this invention is concerned more particularly 
with the performance of a signal transmission chain rather than the 
performance of a single compression coder or decoder, or indeed of a 
transmission coder and decoder pair (codec). 

15 In a signal transmission chain, several codecs might be connected in 

cascade with switching, re-multiplexing or other processing operations 
performed between each codec. In addition, the start (or indeed, any 
intermediate point of the chain) may involve some pre-processing such as 
noise reduction, and the end of the chain (or again, an intermediate point) 

20 may involve some post-processing such as display conversion. 

In a conventional signal chain, each codec pair operates in isolation 
from other codecs and from the intervening signal processes. This can lead 
to inefficiency and loss of performance; inefficiency because each encoder is 
obliged to recalculate all its coding parameters such as motion vectors, and 

25 loss of performance because impairments introduced at an earlier point in 

the chain might unknowingly be re-coded as picture information. 

It is an object of one form of the present invention to provide an 
improved signal transmission chain which removes or reduces this 
inefficiency and loss of performance. 

30 Accordingly, the present invention consists, in one aspect, in a signal 
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.transmission chain comprising at least one compression coder adapted to- * 
receive a signal and to generate therefrom a compressed or partially 
compressed coded signal and at least one compression decoder adapted to 
receive a compressed or partially compressed coded signal and to generate 
5 therefrom a decoded or partially decoded signal, characterised in that an 
information bus extends from a decoder or to a coder in the chain, the 
information bus carrying information relating to an earlier coding operation 
for use in a later signal process. 

Suitably, the information bus extends from a decoder to a later coder 

10 in the chain. 

In the preferred example, the decoded signal is a picture signal. 
In one form of the invention, the information bus is used in a post- 
processing operation such as display upconversion. Similarly, in some 
arrangements according to the invention, an information bus is generated in 

15 a pre-processing operation such as motion compensated noise reduction. 

Within a signal processing chain, the information bus may additionally be of 
assistance within signal processes other than encoding/decoding, an 
example here being motion compensated standards conversion. 

This invention is not restricted to any particular compression 

20 technology but MPEG-2 will be taken as an example. It is known within 

MPEG-2 that a compressed or coded picture signal within a codec pair is 
usefully accompanied by side chain information. This side chain information 
may be similar to information which the present invention supplies on the 
information bus. Indeed, it will be convenient to generate the information 

25 bus from the side chain. It should be stressed, however, that the invention 

is providing something very different from what has pr3viously been 
proposed under MPEG-2. The existence of a side chain within a codec pair 
cannot cure the inefficiency and loss of performance which has been 
described as arising between one codec pair and another in a complete 

30 signal transmission chain. It is the proposal according to the present 

invention in which the output of a decoder (usually a full bandwidth picture 
signal, but sometimes a partially decoded signal) which is accompanied by 
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an information bus r so that subsequent encoding or other processing in later 
portions of the transmission chain can make use of the information about 
earlier encoding. 

The present invention, in a further aspect, recognizes that certain 
video processes hitherto conducted by first decoding a compressed signal to 
a picture, can very usefully be conducted without leaving the compressed 
domain. One example is bit rate conversion where, for example, a 
compressed signal at 6 Mbits/s must be converted for transmission along a 
channel capable of supporting only 4 Mbit/s. Decoding the 6 Mbit/s signal 
and re-encoding at 4 Mbit/s, runs the risk of introducing fresh errors and is 
inefficient. It is an object of this invention to provide an improved method of 
processing which overcomes this problem. 

Accordingly, the present invention consists, in a further aspect, in a 
method of processing a compressed signal, comprising the steps of variable 
length decoding the signal; inverse quantising such decoded signal to 
produce a coefficient stream; re-quantising the coefficient stream optionally 
at a new bit rate and variable length coding the re-quantised, coefficient 
stream. 

This aspect of the invention will find applications outside bit rate 
conversion. It will for example be necessary in some applications to 
combine compressed signals. This will arise in relation to the so-called 
SNR profile of MPEG-2, which will now be described. 

There are defined within MPEG-2, different profiles and levels which 
are - broadly speaking - directed toward different video applications. Tnus, 
for example, "Main Profile" at "Main Level" MPEG-2 provides only for 
standard definition television whereas the "Spatially Scalable Profile" at the 
same level can also accommodate high definition display. 

Certain profiles within MPEG-2 employ the concept of "layering". 
This intended to enable decoders of different sophistication to operate upon 
the same coded signal. A basic decoder might make use of only the lowest 
layer of information in the coded signal; a more advanced decoder would 
make use of a higher layer or layers. 
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There is believed to. be a need within MPEG-2 to provide for a coded 
signal which is resilient in the face of less than optimal transmission 
channels. By this is meant a coded signal which contains sufficient 
information for the regeneration of a high quaiity picture, but in a form which 
5 can still sensibly be decoded if a portion of the information is lost, albeit to 

produce a picture of reduced quality. In this context, the concept of layers is 
again employed with a basic layer of information being routed at all times 
through the highest priority and most reliable path in the transmission 
channel. One or more enhancement layers, which are not essential for the 
10 regeneration of a picture but which improve performance, are sent along 

lower priority paths. One profile operating in this manner under MPEG-2 is 
the so-called SNR Profile. 

An SNR Profile MPEG-2 coder will output two coded streams; a 
lower layer containing the most significant digits of the DCT coefficients and 
15 an enhancement layer containing the least significant digits, in both cases 

quantised and variable length coded. The SNR Profile signal is of course 
not compatible with a Main Profile decoder, unless the enhancement layer is 
discarded. 

Already, Main Profile decoders are available relatively cheaply in 
20 standard VLSI form; this will not be the case for SNR Profile decoders for 

some time. Accordingly, there would in a number of applications be 
economic advantage in converting an SNR Profile signal in two streams, to a 
single stream Main Profile signal. The trivial example of decoding from one 
profile to a picture and recoding that picture at the new profile, is obviously 
25 unhelpful. 

It is one object of this further aspect of the invention to provide for the 
conversion of an SNR Profile MPEG-2 signal in two streams into a Main 
Profile signal with the minimum of processing and with minimal loss of 
information. 

30 It is a further object of this aspect of the invention to provide for 

elegant and straightforward processing of an MPEG-2 or other compressed 
signal. 



WO 95/35628 



PCT/GB95/01433 



- 5 - 

Accordingly, the present invention consists, in a further aspect, in a 
method of combining a plurality of compressed signals, comprising the steps 
of variable length decoding each compressed signal; inverse quantising each 
such decoded signal to produce a coefficient stream; combining the 
5 coefficient streams to form a combined coefficient stream; re-quantising the 
combined coefficient stream and variable length coding the re-quantised, 
combined coefficient stream. 

Preferably, the compressed signals comprise at least two layers of An 
SNR profile MPEG-2 signal. 

10 The present invention recognises that there exists a novel, 

intermediate domain in which different layers (such as the lower and 
enhancement layers in the SNR profile) are readily combinable. Once 
synchronicity has been ensured, for example, it will usually be possible for 
the two streams to be simply added. This intermediate domain will be 

15 referred to as the coefficient domain. 

The present invention will have application well beyond 
bit rate conversion and the conversion of dual SNR profile streams to main 
profile format. It will be possible to perform other useful processing within 
the coefficient domain. Thus, the invention will find application in re- 

20 multiplexing. It will permit - for example - the de-multiplexing of a group of 

channels, the addition of a further channel in synchronism, and re- 
multiplexing - all without returning to the level of pixels. Establishing 
sychronocity between two slightly out of sync bit streams, will sometimes be 
an end in itself, again readily accomplished in the coefficient domain, 

25 following the present invention. 

The formation of an information bus for MPEG-2 has already been 
proposed. Information from the variable length decoding according to the 
present invention can conveniently feed an information bus generator. This 
same information can in accordance with the present invention, be supplied 

30 to a microcontroller or microprocessor controlling the re-quantisation step to 

maximise re-coding efficiency and optimise buffer occupancy. Indeed, the 
ability to extract coding information from an incoming MPEG stream, without 
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decoding to pixels, is itself an important advantage offered by the present, 
invention. 

The present invention will now be described by way of example with 
reference to the accompanying drawing in which:- 
. 5 Figure 1 is a. block diagram of an illustrative picture signal . 

transmission chain according to the present invention; 

Figure 2 is a block diagram of an information bus generator according 
to the invention; 

Figure 3 is a block diagram illustrating in more detail, certain 
10 components of the circuit shown in Figure 2; 

Figure 4 is a block diagram of an information bus interface according 
to the invention; 

Figure 5 is a block diagram of an information bus originator according 
to the invention; 

15 Figure 6 is a block diagram of an information bus inserter according 

to the invention; 

Figure 7 is a block diagram of an information bus interpreter 
according to the invention; 

Figure 8 is a block diagram of an information bus encoder according 
20 to the invention; 

Figure 9 is a block diagram of a bit rate converter according to the 
invention; and 

Figure 10 is a block diagram of an SNR layer combiner according to 
the invention. 

25 Figure 1 shows an illustrative signal transmission chain comprising 

four compression coders and three decoders, some of which incorporate the 
information bus, together with some intervening processing. A picture signal 
P forms the input to a pre-processor 10 which performs a function such as 
motion-compensated noise reduction. The output of the pre-processor is a 

30 picture signal P and an information bus signal IB which together form the 

input to a first compression coder 12. The information bus contains 
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information which might assist the coding process, such as recommended 
motion vectors or the identification of material having film or video origins 
and, for film, detection of the phase of the 3:2 pulldown telecine sequence. 
Within coder 12, the information bus can be used as an internal path for 
5 . coding, decisions, so it may be modified by the coder's own decision 

processes such as coding mode selection and rate control. Ultimately, the 
information bus contains all the side information that is sent alongside the 
DCT coefficients in a conventional MPEG-2 bitstream. 

The path between coder 12 and decoder 14 is a coded picture signal 

10 CP in the form of an unmodified bitstream consisting of the DCT coefficients 

and the side information. Decoder 14 is a partial decoder, which means that 
its main output CP* is not a fully decoded picture signal but a signal decoded 
to some intermediate stage, here for example DCT coefficients. The use of 
such an intermediate domain is mentioned above and will be described in 

15 more detail below. The second output from the partial decoder 14 is an 

information bus signal IB, which consists of the side information decoded 
from the transmitted bitstream. As in coder 12, the information bus can 
additionally be used within the decoder as an internal path by which side 
information is communicated throughout the partial decoding process. 

20 In this example, the information bus IB and partially decoded picture 

CP* outputs of decoder 14 are fed to an information bus processor 16, which 
also receives equivalent inputs from a second partial decoder 18 linked to a 
second coder 20. The function of the information bus processor is to 
combine the two partially decoded picture signals CP* in some way, making 

25 advantageous use in this of the two information bus bitstreams IB, and to 

produce a new information bus output IB alongside the combined partially 
decoded picture signal output CP*. For example, the information bus 
processor might include an intelligent switcher that takes information about 
the instantaneous bit-rates and group-of-pictures (GOP) structures used in 

30 the two previous codecs and uses it to minimize artifacts and to maximize 

coding efficiency in the subsequent partial coding process in coder 22. In 
this example, coder 22 can be essentially a "dumb" partial coder in that- it 
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simply obeys the coding decisions conveyed to it by the information bus. 

.The coded output CP of coder 22 is decoded by decoder 24, which 
for the sake of this example is a conventional MPEG-2 decoder with a fully 
decoded picture output P and no information bus output. This illustrates that 
5 it is not necessary to use information bus processing throughout a 

transmission chain in order for it to have benefit. In fact, the information bus 
can exist, in islands between decoders and subsequent encoders. 

The output of decoder 24 is passed through some studio processing 
in block 26, for example a standards conversion, which in this example is 
10 not provided with an information bus processing. In another arrangement, 

however, the standards conversion would make use of information bus 
processing. 

Coder 28 is a conventional coder which makes no use of an 
information bus input (though information bus processing may have been 

15 used advantageously within the coder as a means of controlling the 

individual coding steps and of formatting the side information prior to 
insertion in the video multiplex). Its output CP is decoded by decoder 30 
which uses information bus processing but differs from decoders 14 and 18 
in that its main output is a fully decoded picture signal P. This picture signal 

20 and its associated information bus IB are fed to a post-processor 32 which 

performs a display-related function such as field rate up-conversion. Here, 
the information bus bitstream is used advantageously to assist the post- 
processor, for example by providing motion vectors. It is recognized that the 
motion vectors may themselves need some post-processing to adapt them 

25 to the display upconversion application. However, this requirement can be 

minimized by the use of "true" motion vectors in the motion estimator of 
coder 28. By this is meant that the "motion" vectors in compression 
techniques have usually hitherto been selected with the sole aim of providing 
efficient compression; vectors selected according to this criterion are not 

30 necessarily the most accurate measures of motion available. If it is elected 

to use "true" motion vectors for the compression procedures, the advantage 
is obtained that the motion vectors can, as explained, be used with minimum 
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further treatment in the display upconversion or other motion compensated 
process. 

A particular example of the physical format of the information bus will 
now be described. In essence, the information bus signal is a digital signal 
5 that accompanies a picture signal or a partially encoded or decoded picture 
signal. It contains two parts which may be time multiplexed together, though 
other means of combining the two. parts are not excluded. The first part 
(which may be regarded as the core information) consists of all the side 
information that controls the compression coding or decoding, typically in a 
10 form from which individual pieces of information can easily be extracted. In 

practice, this means that the core information is carried in a fixed-length 
coding format, in contrast to coded bitstream format which may involve 
variable-length coding. The core information consists of, predominantly, 
motion vectors with additional information such as the number of the coding 
15 mode currently in use and the quantisation step size. The second part 

consists of additional information which is related to the control of the coding 
or decoding process but which does not form part of the coded bitstream. It 
includes, for example, statistical information such as the number of bits 
being used for coding luminance and chrominance blocks and for coding 
20 motion vectors. It will usually also include information concerning errors 

together with instructions for use in error concealment. Candidate motion 
vectors or recommended quantizer step sizes may also be included. 

In the case of MPEG-2, the information bus carries information which 
varies at different rates: sequence, GOP, picture, slice and macrobiock. It is 
25 also intended to be kept in synchronism with the picture signal, which for 

most of its life within the codec may be in a macrobiock scanning format 
with a picture blanking interval. For this reason, one particular form of the 
information bus is arranged in a two level structure, with sequence, GOP 
and picture rate information carried in the picture blanking interval and slice 
30 and macro-block rate information carried in a macrobiock based structure 

that is co-timed with the picture signal. 
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The information rate required for the . information bus necessitates a 
parallel signal format, if the clock rate used for the picture signal is to be 
retained. In one particular embodiment, a four bit wide signal is used 
internally. For external use, this signal is converted to a format compatible 
. 5 with the luminance component of a CCIR Rec.656 signal, so that it pass 

between existing devices. Jn both cases, macroblock and picture addressing 
information is included in the format so that synchronism with the picture 
signal can easily be verified. 

The information bus will in this example include at least two timing 
10 signals: a picture rate signal and a macroblock signal. These signals are 
used, as will be described, in information interpreters and inserters which 
decode, update or insert selected pieces of information within the information 
bus. 

Dealing first with picture rate information, this - as mentioned - will 
15 include "repeats" of information changing at the GOP or sequence level. To 

facilitate use by devices which require only "true" picture rate information, 
the picture rate information may usefully be provided in two bursts, the first 
of which contains all the GOP and sequence information and can be ignored 
by devices if they choose. The first burst of the picture rate information 
20 might therefore include:- 

Burst I 

Global picture rate information 

New sequence and GOP header flags 
MPEG1/MPEG2 flag 
25 Decoded or "raw" motion vectors flag 

Sequence rate information 

Horizontal and vertical sizes 
Aspect ratio 
Frame rate 
30 Colour information 

GOP rate information 
Time code 
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The second burst will include picture rate information such as :- 
Burst II 

Core information 

Time reference 
5 Coding type 

Horizontal and vertical display offsets 
Quantiser matrix information 
Non-core information 

Motion vector source 
10 Cut detection 

Numbers of l,P and B frames remaining in GOP 
Film phase (or 3:2 pulldown) detection 
Field or frame like index 
Pan vector identification 
15 Letterbox detection 



Turning now to macro rate information, this can be broken down into 
address information, core information (which may include slice rate 
information) and derived or non-core information. Examples are:- 



Address information 
20 Picture address 

Stripe number 
Position within stripe 



Core information 

Macroblock type 
25 Motion type (field/frame) 

Motion vector types 
Motion vectors 
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Derived information 

Macroblock scan mode 
Error concealment flag 
Causes for concealment 
.5 Numbers of bits used for:- 

Motion vectors 
Other overheads 
Luminance 
Chrominance 
10 Candidate motion vectors 



Examples of apparatus implementing the information bus, in addition 
to the information bus processor referred to above, will now be described, 
again with particular reference to MP EG -2. 

Referring to Figure 2, there is shown a decoder information bus 

15 generator 200. Briefly, with respect to a timebase synchronous with the 

decoded picture signal, derived from transmitted clock reference and 
timestamp information, a picture and macroblock rate stream of nibbles (4- 
bit words) is generated containing the side information decoded from the 
bitstream, together with macroblock addressing information, according to a 

20 predetermined fixed structure map. In more detail, a time stamp detector 

201 detects time stamps from an incoming MPEG compressed signal. 
These timestamps are compared in comparator 202 with program clock 
references such that, as a predetermined "MPEG time" is attained, a time 
base is generated in video timebase generator 203 and passed to timing 

25 control logic block 204. This arrangement effectively provides a timing 

interface between the variable length coding world and the video world, 

A start code detector 205 operating on the MPEG signal controls the 
writing of information into either a main FIFO 206 holding macroblock rate 
information and serving as the conventional MPEG buffer, or a picture rate 

30 information FIFO 207. Under control of the timing control logic 204, a 

variable length decoder 203 operates on the output of buffer 206 to derive 
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DCT coefficients which are made available to the remainder of the decoder 
at line 209. The non^-coefficient data is passed to an information bus 
formatter 210. For clarity, the information bus formatter, together with the 
variable length decoder 208, is shown in more detail in Figure 3 to which 
5 . reference is now directed. The variable length decoder 2Q8 can be regarded 
as a state machine and the current state is made available to an 
analyzer 21 1 . This analyzer serves to derive the various types. of "statistical" 
macroblock rate information described above, which then passes to a 
multiplexer 212. This multiplexer receives certain non-coefficient information 
10 (such as motion vectors) directly from the variable length decoder 208. 

Others pieces of information, mainly flags, pass through interpretation 
logic 213. 

Returning to Figure 2, the output of information bus formatter 210 is 
buffered in a FIFO 214 before passing to an information bus output 

15 switcher 216. In a generally similar fashion, picture rate information from 

FIFO 207 is decoded and formatted in microprocessor 217 using RAM 218. 
The function of the information bus formatter 210 is effectively performed at 
picture rate through software in the microprocessor 217. The picture rate 
information bus information is buffered in FIFO before passing as the second 

20 input to switcher 21 6. 

Turning now to Figure 4, there is shown a decoder information bus 
interface which converts from the format described above to a CCiR Rec. 
656 compatible format. This enables straightforward communication 
between separate pieces of equipment and may also allow recording on D1 

25 VTR's. An information bus signal according to this invention is presented to 

a formatting block 401. The information bus signal will typically be 4 bits 
wide and clocked at 18 MHz. The formatter provides an 8 bit wide signal 
which is read at 18 MHz into FIFO 402. The picture timing signal is 
provided as a control signal to a Rec. 656 timebase block 403 which, in turn, 

30 provides a read clock to FIFO 402. In this way, a Rec. 656 information bus 

is output. 
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A coder information bus interface converts from the CCIR Rec. 656 
compatible format to the nibble-wide internaf format In analogous fashion. 

An information bus originator is illustrated in Figure 5. This uses a 
coder's picture signal timebase to create a "blank" nibble-wide information 
5 bus signal with macroblock addressing information but with uncommitted 
information slots. Thus, the picture timing signal is taken as an input to a 
counter 501 which provides address information to a ROM 502 which has 
stored within it a "blank" information bus for an entire picture. 

Referring now to Figure 6, there is shown an information inserter 

10 which serves to take a particular piece of information and insert it to the 
appropriate slot in the information bus format. This can operate to "fill" a 
blank information bus as described above or to update one particular piece 
of information in an existing and fully functioning information bus. The 
approach taken is that the piece of information to be inserted is written to a 

15 register 601 and the location of that piece of information in terms of clocks is 

provided as one input to a comparator 602. A counter 603 receives picture 
and macroblock timing signals as appropriate and provides the second input 
to comparator 602. At the correct time-slot, the output of comparator 602 
controls switch 604 to insert the contents of register 601 into the information 

20 bus. 

An information interpreter is required to decode a particular piece of 
information from the information bus and an example is shown in Figure 7. 
Picture and macroblock timing signals P S>TK and MB c are taken to 
. respective counters 701 and 702. The outputs of these counters are 
25 compared in respective comparators 703 and 704 with the address of the 

required piece of information held in address store 705. The information bus 
signal passes continuously through parallel registers, only one of which is 
shown in the drawing at 707. The contents of the appropriate register are 
then read out as the counted P sync and MB sync signals coincided with the 
30 preset address. 

Figure 8 illustrates an example of an information bus encoder. Tnis 
serves at the end of a coder's processing to convert the information bus into 
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• a form suitable for transmission alongside the coefficient information. Thus, 
the information bus is presented to parallel paths each of which contains an 
information bus interpreter 801 as previously described. This feeds a 
variable length coder 802. The outputs of the variable length coders 802, 
5 together with the output of a variable length coder 804 operating on the 

coefficient information, serve as inputs to a multiplexer 803 which generates 
the required MPEG-2 bitstream. 

In another embodiment, the present invention provides a bit rate 
converter. This may be required, for example, to convert an MPEG-2 signal 

10 at 6 MBit/s to a signal compressed at 4 MBit/s. An example of a bit rate 

converter according to the present invention is shown in Figure 9. Thus, an 
MPEG-2 signal received at a terminal 900, passes through an information 
bus decoder 901, which as described above includes a variable length 
decoder, providing an information bus output and a coefficient stream. Tne 

15 latter is taken to an inverse quantisation unit 902 which passes information 

concerning quantisation levels to a first information bus inserter 903 which 
inserts this information into the information bus. A quantisation unit 904 
operates under control of a microprocessor 905 to re-quantise the signal at 
quantisation levels appropriate to the desired output bit rate. The output of 

20 quantisation unit passes through a variable length encoder 905 to a buffer 

906 from which information can be read at the desired bit rate. Buffer 
occupancy is monitored by the microprocessor 905 which controls 
quantisation levels in the quantisation unit 904 to avoid overflow. Use may 
be made by the microprocessor of information taken from the information 

25 bus in interpreter 907. Similar, new quantisation levels selected by the 

microprocessor are added to the information bus by a second information 
bus interpreter 908. The updated information bus and coefficient stream can 
be combined in an information bus decoder as previously described to 
provide an MPEG-2 output. 

30 In still another embodiment, the present invention provides an SNR 

layer combiner. This as mentioned above serves to convert an SNR Profile 
signal in two streams, to a single stream Main Profile signal. Thus referring 
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to Figure 10, the lower SNR layer received at a terminal 110, passes 
through a lower layer buffer 112 and is variable length decoded in a 
VLD 114 utilising the look up table 116. Similarly, the enhancement SNR 
layer, received at a terminal 118 through an enhancement layer buffer 120, 
5 is decoded in a VLD 122 using the look up table 124. It will be understood 
that the table contents need not be constant but can be switched from set to 
set dynamically, in dependence upon picture character. Overflow in the 
decoding paths, through variation in the rate in which coded information is 
received, is avoided through the buffers 112 and 120. 
10 During the decoding process, information concerning the efficiency 

and other aspects of the decoding procedure is fed to an information bus 
generator 132. 

Output from the lower layer VLD 114 passes, through an inverse 
quantisation unit 126 and a delay 128, to an adder 130 which similarly 

15 receives, through inverse quantisation unit 134 and a deiay 136, the output 

from the enhancement layer VLD 122. It will be understood that the function 
of adder 130 is to recreate the original unquantised coefficient stream. This 
is then quantised afresh in quantisation unit 138 under the control of a 
microprocessor 140 which receives information from the information bus 

20 generator 132. The output from the quantisation unit 138 is recoded in a 

VLC 142 using look up table 144, with the output passing through output 
buffer 146 to a Main Profile output terminal 148. The microprocessor 140 
seeks to control the re-quantisation procedure so that the output buffer 146 
neither overflows nor underflows. 

25 The circuit can also make available, on respective terminals 150 

and 152, the coefficient level lower and enhancement levels for inverse DCT 
and pixel regeneration, if required. 

It will be understood that the applications of bit rate conversion and 
recombining SNR streams in MPEG-2 have been described merely as 

30 examples of this aspect of the present invention. Alternative examples of 

synchronising, re-multiplexing, and the extraction of coding information have 
already been mentioned. Still further examples will occur to the skilled man. 



WO 95/35628 



PCT/GB95/01433 



- 17 - 

CLAIMS 

1. A signal transmission chain comprising at least one compression 
coder adapted to receive a signal and to generate therefrom a compressed 
or partially compressed coded signal and at least one compression decoder 
5 adapted to receive a compressed or partially compressed coded signal and 
to generate therefrom a decoded or partially decoded signal, characterised ' 
in that an information bus extends from a decoder or to a coder in the chain, 
the information bus carrying information relating to a coding operation for 
use in a later signal process. 

10 2. A signal transmission chain according to Claim 1, wherein the 

information bus extends from a decoder to a later coder in the chain. 

3. A signal transmission chain according to Claim 2, wherein the 
information bus carries information relating to a decoding process in said 
decoder for use in an encoding process in said coder. 

15 4. A signal transmission chain according to any one of the preceding 

claims wherein the information bus carries motion vector information 
together with at least one piece of information selected from the group 
consisting of macroblock scan mode; error concealment flag; causes for 
concealment; numbers of bits used per block; and candidate motion vectors. 

20 5. A signal transmission chain according to any one of the preceding 

claims wherein the information bus carries motion vector information 
together with at least one piece of information selected from the group 
consisting of motion vector source; cut detection; numbers of l,P and B 
frames remaining in GOP; film phase (or 3:2 pulldown) detection; field or 

25 frame like index; pan vector identification; and letterbox detection. 
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6. An information bus generator, comprising timestamp driven timing 
means; a macroblock rate information buffer;. a variable length decoder 
operating on the buffer output to derive coefficient and non-coefficient 
streams; means for formatting the non-coefficient stream to provide a first 
information bus component; means for monitoring the state of the. variable 
length decoder to provide a second information bus component and means 
for combining the first and second information bus components to. provide an 
information bus. 

7. An MPEG or other video compression decoder including an 
information bus generator according to Claim 6. 

8. An information bus encoder comprising a variable length coder for 
receiving a coefficient stream; a plurality of parallel paths each serving to 
interpret and code a piece of information from an information bus and 
multiplexer means serving to combine all said coded information in a 
compressed bitstream. 

9. An MPEG or other video compression encoder including an 
information bus encoder according to Claim 8. 

10. A method of processing a compressed signal, comprising the steps of 
variable length decoding the signal; inverse quantising such decoded signal 
to produce a coefficient stream; re-quantising the coefficient stream 
optionally at a new bit rate and variable length coding the re-quantised, 
coefficient stream. 

11. A method according to Claim 10, wherein the step of re-quantising 
the coefficient stream includes the steps of monitoring an output buffer and 
varying the quantisation level of the re-quantisation process to avoid buffer 
overflow. 
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12. A method of combining a plurality of compressed signals, comprising 
the steps of variable length decoding each compressed signal; inverse 
quantising each such decoded signal to produce a coefficient stream; 
combining the coefficient streams to form a combined coefficient stre.am; re- 
quantising the combined coefficient stream and variable length coding the. 
re-quantised, combined coefficient stream. 

13. A method according to Claim 12, wherein the compressed signals 
comprise at least two layers of an SNR profile MPEG-2 signal. 

14. The method of video signal processing, comprising the steps of variable 
length decoder a compressed video signal to derive coefficient and non- 
coefficient streams; formatting the non-coefficient stream to provide a first 
information bus component; monitoring the state of the variable iength 
decoder to provide a second information bus component and combining the 
first and second information bus components to provide an information bus. 

15. An information bus signal companion to a synchronous coefficient 
stream, including information derived from a previous decoding operation for 
use in a subsequent coding operation. 

16. An information bus signal companion to a synchronous coefficient 
stream, including information derived from a pre-processing operation for 
use in a subsequent coding operation. 

17. An information bus signal companion to a synchronous coefficient 
stream, including information derived from a previous decoding operation for 
use in a post-processing operation. 

18. An information bus according to any one of Claims 15 to 17, wherein 
the information bus carries motion vector information together with at least 
one piece of information selected from the group consisting of macroblock 
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scan mode; error concealment flag; causes for concealment; numbers of bits 
used per block;, and candidate motion vectors. 

19. An information bus according to any one of Claims 15 to 18, wherein 
the information bus carries motion vector information together with at least 
one piece of information selected from the group consisting of motion vector 
source; cut detection; numbers of l,P and B frames remaining in GOP; film 
phase (or 3:2 pulldown) detection; field or frame like index; pan vector 
identification; and letterbox detection. 
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